package com.knowledgeqa.system.mapper;

import com.knowledgeqa.system.entity.Question;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
import java.util.Map;

/**
 * 问题Mapper接口
 */
@Mapper
public interface QuestionMapper {
    /**
     * 根据ID查询问题
     */
    Question selectById(Long id);

    /**
     * 根据用户ID查询问题
     */
    List<Question> selectByUserId(Long userId);

    /**
     * 分页查询问题列表
     */
    List<Question> selectPage(Map<String, Object> params);

    /**
     * 查询问题总数
     */
    int selectCount(Map<String, Object> params);

    /**
     * 新增问题
     */
    int insert(Question question);

    /**
     * 更新问题信息
     */
    int update(Question question);

    /**
     * 删除问题
     */
    int deleteById(Long id);

    /**
     * 更新问题状态
     */
    int updateStatus(Long id, Integer status);

    /**
     * 更新浏览量
     */
    int updateViewCount(Long id);

    /**
     * 更新回答数
     */
    int updateAnswerCount(Long id);

    /**
     * 查询悬赏金额最高的前N个问题
     */
    List<Question> selectTopRewardedQuestions(Integer limit);

    /**
     * 查询悬赏金额最高的前三个问题
     */
    List<Question> selectTop3RewardedQuestions();

    /**
     * 查询浏览量最高的前N个问题
     */
    List<Question> selectTopViewedQuestions(Integer limit);

    /**
     * 查询浏览量最高的前三个问题
     */
    List<Question> selectTop3ViewedQuestions();
}